// 导航守卫
import router from '@/router'
import store from '@/store'
// 导入进度条
import Nprogress from 'nprogress'
import 'nprogress/nprogress.css'
// 创建白名单
const whitepaper = ['/404', '/login']
// 前置导航守卫
router.beforeEach(async (to, from, next) => {
  Nprogress.start()
  // 判断是否已经登录
  if (store.getters.token) {
    // 去登录页
    if (to.path.toLowerCase() === '/login') {
      next('/')
    } else {
      // 验证token获取用户信息
      // 判断是否存在用户信息
      // 如果有就不再调用
      if (!store.state.user.userInfo.userId) {
        await store.dispatch('user/getUserInfo')
        // 因为动态添加的路由不能立马使用，再经过一次导航守卫就可以正常使用了
        next(to.fullPath)
      } else {
        next()
      }
    }
  } else {
    // 没有登录
    if (whitepaper.includes(to.path.toLowerCase())) {
      next()
    } else {
      next('/login')
    }
  }
  Nprogress.done()
})
// 导航后置守卫
router.afterEach((to, from) => {
  Nprogress.done()
})
